1 /* ====================================================================
2 * The Apache Software License, Version 1.1
3 *
4 * Copyright (c) 2000 The Apache Software Foundation. All rights
5 * reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 *
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in
16 * the documentation and/or other materials provided with the
17 * distribution.
18 *
19 * 3. The end-user documentation included with the redistribution,
20 * if any, must include the following acknowledgment:
21 * "This product includes software developed by the
22 * Apache Software Foundation (http://www.apache.org/)."
23 * Alternately, this acknowledgment may appear in the software itself,
24 * if and wherever such third-party acknowledgments normally appear.
25 *
26 * 4. The names "Apache" and "Apache Software Foundation" must
27 * not be used to endorse or promote products derived from this
28 * software without prior written permission. For written
29 * permission, please contact apache@apache.org.
30 *
31 * 5. Products derived from this software may not be called "Apache",
32 * nor may "Apache" appear in their name, without prior written
33 * permission of the Apache Software Foundation.
34 *
35 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46 * SUCH DAMAGE.
47 * ====================================================================
48 *
49 * This software consists of voluntary contributions made by many
50 * individuals on behalf of the Apache Software Foundation. For more
51 * information on the Apache Software Foundation, please see
52 * <http://www.apache.org/>.
53 *
54 * Portions of this software are based upon public domain software
55 * originally written at the National Center for Supercomputing Applications,
56 * University of Illinois, Urbana-Champaign.
57 */
58
59 package net.sourceforge.jane.lang.reflection;
60
61 import java.lang.reflect.Constructor;
62 import java.lang.reflect.Member;
63 import net.sourceforge.jane.lang.*;
64
65 /***
66 * Constructor information derived from a <code>java.lang.reflect.Constructor</code>.
67 *
68 * @author Calvin Yu
69 */
70 public class ReflectionConstructorInfo extends MemberElementBase
71 implements ConstructorInfo
72 {
73
74 private Constructor constructor;
75
76 /***
77 * Create a new <code>ReflectionConstructorInfo</code>.
78 */
79 public ReflectionConstructorInfo(Constructor aConstructor)
80 {
81 constructor = aConstructor;
82 }
83
84 /***
85 * Returns the exception thrown by this method.
86 */
87 public Classes getExceptions()
88 {
89 return new ReflectionClasses(constructor.getExceptionTypes());
90 }
91
92 /***
93 * Returns the parameters of this method.
94 */
95 public Parameters getParameters()
96 {
97 return new ReflectionParameters();
98 }
99
100 /***
101 * Returns the member.
102 */
103 protected Member getMember()
104 {
105 return constructor;
106 }
107
108 /***
109 * A {@link Parameters} implementation.
110 */
111 private class ReflectionParameters extends Parameters
112 {
113 /***
114 * Returns the number of parameters.
115 */
116 public int getParameterCount()
117 {
118 return constructor.getParameterTypes().length;
119 }
120
121 /***
122 * Returns the parameter at the given index.
123 */
124 public ParameterInfo getParameter(int index)
125 {
126 return new ReflectionParameterInfo(index);
127 }
128 }
129
130 /***
131 * A {@link ParameterInfo} implementation.
132 */
133 private class ReflectionParameterInfo extends SimpleParameterInfo
134 {
135 /***
136 * Create a new <code>ReflectionParameterInfo</code>.
137 */
138 public ReflectionParameterInfo(int anIndex)
139 {
140 super(anIndex);
141 }
142
143 /***
144 * Returns the parameter type.
145 */
146 public ClassInfo getType()
147 {
148 return new ReflectionClassInfo(constructor.getParameterTypes()[index]);
149 }
150 }
151
152 }
153
This page was automatically generated by Maven